[INFO] cloning repository https://github.com/dixe/rust-sdf-tool
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/dixe/rust-sdf-tool" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdixe%2Frust-sdf-tool", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdixe%2Frust-sdf-tool'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 729034f68abf67f56de7e57a2d8ee8d22deeb4ea
[INFO] checking dixe/rust-sdf-tool against try#b152f5575a2ac7126ae0019e4e679abe9399213e for pr-157841
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdixe%2Frust-sdf-tool" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/dixe/rust-sdf-tool
[INFO] finished tweaking git repo https://github.com/dixe/rust-sdf-tool
[INFO] tweaked toml for git repo https://github.com/dixe/rust-sdf-tool written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dixe/rust-sdf-tool on toolchain b152f5575a2ac7126ae0019e4e679abe9399213e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b152f5575a2ac7126ae0019e4e679abe9399213e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/dixe/rust-sdf-tool already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b152f5575a2ac7126ae0019e4e679abe9399213e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking dixe/rust-sdf-tool against try#b152f5575a2ac7126ae0019e4e679abe9399213e for pr-157841
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdixe%2Frust-sdf-tool" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/dixe/rust-sdf-tool
[INFO] finished tweaking git repo https://github.com/dixe/rust-sdf-tool
[INFO] tweaked toml for git repo https://github.com/dixe/rust-sdf-tool written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dixe/rust-sdf-tool on toolchain b152f5575a2ac7126ae0019e4e679abe9399213e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b152f5575a2ac7126ae0019e4e679abe9399213e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/dixe/rust-sdf-tool already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b152f5575a2ac7126ae0019e4e679abe9399213e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded crossbeam-utils v0.8.11
[INFO] [stderr]   Downloaded futures-sink v0.3.24
[INFO] [stderr]   Downloaded bit_field v0.10.1
[INFO] [stderr]   Downloaded threadpool v1.8.1
[INFO] [stderr]   Downloaded either v1.8.0
[INFO] [stderr]   Downloaded futures-core v0.3.24
[INFO] [stderr]   Downloaded cmake v0.1.48
[INFO] [stderr]   Downloaded pin-project-internal v1.0.12
[INFO] [stderr]   Downloaded once_cell v1.15.0
[INFO] [stderr]   Downloaded getrandom v0.2.7
[INFO] [stderr]   Downloaded unicode-ident v1.0.4
[INFO] [stderr]   Downloaded nanorand v0.7.0
[INFO] [stderr]   Downloaded bytemuck v1.12.1
[INFO] [stderr]   Downloaded spin v0.9.4
[INFO] [stderr]   Downloaded cc v1.0.72
[INFO] [stderr]   Downloaded flume v0.10.14
[INFO] [stderr]   Downloaded proc-macro2 v1.0.43
[INFO] [stderr]   Downloaded crossbeam-epoch v0.9.10
[INFO] [stderr]   Downloaded png v0.17.6
[INFO] [stderr]   Downloaded miniz_oxide v0.5.4
[INFO] [stderr]   Downloaded pin-project v1.0.12
[INFO] [stderr]   Downloaded bumpalo v3.11.0
[INFO] [stderr]   Downloaded image v0.24.3
[INFO] [stderr]   Downloaded flate2 v1.0.24
[INFO] [stderr]   Downloaded freetype-rs v0.31.0
[INFO] [stderr]   Downloaded exr v1.5.1
[INFO] [stderr]   Downloaded syn v1.0.100
[INFO] [stderr]   Downloaded libc v0.2.133
[INFO] [stderr]   Downloaded jpeg-decoder v0.2.6
[INFO] [stderr]   Downloaded tiff v0.7.3
[INFO] [stderr]   Downloaded freetype-sys v0.16.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-m" "1610612736" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3e793bdf10248eb2ddbd6b0faebed8155c11b4589982e2893733958d93e8d540" "sleep" "infinity", kill_on_drop: false }`
[INFO] [stdout] 45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6
[INFO] running `Command { std: "docker" "start" "45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-w" "/opt/rustwide/workdir" "--user" "0:0" "45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6" "/opt/rustwide/cargo-home/bin/cargo" "+b152f5575a2ac7126ae0019e4e679abe9399213e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "exec" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-w" "/opt/rustwide/workdir" "--user" "0:0" "45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6" "/opt/rustwide/cargo-home/bin/cargo" "+b152f5575a2ac7126ae0019e4e679abe9399213e" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.133
[INFO] [stderr]    Compiling crossbeam-utils v0.8.11
[INFO] [stderr]    Compiling proc-macro2 v1.0.43
[INFO] [stderr]     Checking once_cell v1.15.0
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.10
[INFO] [stderr]    Compiling quote v1.0.21
[INFO] [stderr]    Compiling unicode-ident v1.0.4
[INFO] [stderr]    Compiling syn v1.0.100
[INFO] [stderr]    Compiling rayon-core v1.9.3
[INFO] [stderr]     Checking adler v1.0.2
[INFO] [stderr]    Compiling rayon v1.5.3
[INFO] [stderr]    Compiling cc v1.0.72
[INFO] [stderr]    Compiling futures-core v0.3.24
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling pkg-config v0.3.25
[INFO] [stderr]     Checking either v1.8.0
[INFO] [stderr]     Checking miniz_oxide v0.5.4
[INFO] [stderr]     Checking spin v0.9.4
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking weezl v0.1.7
[INFO] [stderr]     Checking futures-sink v0.3.24
[INFO] [stderr]     Checking bit_field v0.10.1
[INFO] [stderr]     Checking half v1.8.2
[INFO] [stderr]     Checking smallvec v1.9.0
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking lebe v0.5.2
[INFO] [stderr]     Checking bytemuck v1.12.1
[INFO] [stderr]     Checking scoped_threadpool v0.1.9
[INFO] [stderr]     Checking gif v0.11.4
[INFO] [stderr]     Checking crossbeam-channel v0.5.6
[INFO] [stderr]    Compiling cmake v0.1.48
[INFO] [stderr]     Checking flate2 v1.0.24
[INFO] [stderr]     Checking num_cpus v1.13.1
[INFO] [stderr]     Checking getrandom v0.2.7
[INFO] [stderr]     Checking crossbeam-deque v0.8.2
[INFO] [stderr]    Compiling freetype-sys v0.16.0
[INFO] [stderr]     Checking threadpool v1.8.1
[INFO] [stderr]     Checking nanorand v0.7.0
[INFO] [stderr]     Checking png v0.17.6
[INFO] [stderr]     Checking freetype-rs v0.31.0
[INFO] [stderr]     Checking jpeg-decoder v0.2.6
[INFO] [stderr]     Checking tiff v0.7.3
[INFO] [stderr]    Compiling pin-project-internal v1.0.12
[INFO] [stderr]     Checking pin-project v1.0.12
[INFO] [stderr]     Checking flume v0.10.14
[INFO] [stderr]     Checking exr v1.5.1
[INFO] [stderr]     Checking image v0.24.3
[INFO] [stderr]     Checking rust-sdf-tool v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::fmt::Write`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt::Write;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Cursor`
[INFO] [stdout]  --> src/main.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::io::Cursor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude::*`
[INFO] [stdout]  --> src/fntfont.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `image::imageops`
[INFO] [stdout]  --> src/fntfont.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use image::imageops;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Write`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt::Write;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Cursor`
[INFO] [stdout]  --> src/main.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::io::Cursor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude::*`
[INFO] [stdout]  --> src/fntfont.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `image::imageops`
[INFO] [stdout]  --> src/fntfont.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use image::imageops;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:141:20
[INFO] [stdout]     |
[INFO] [stdout] 141 |         advance_x: glyph.advance().x >> 6,
[INFO] [stdout]     |                    ^^^^^^^^^^^^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:141:20
[INFO] [stdout]     |
[INFO] [stdout] 141 |         advance_x: glyph.advance().x >> 6,
[INFO] [stdout]     |                    ^^^^^^^^^^^^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:145:19
[INFO] [stdout]     |
[INFO] [stdout] 145 |         offset_x: g_metrics.horiBearingX >> 6,
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:145:19
[INFO] [stdout]     |
[INFO] [stdout] 145 |         offset_x: g_metrics.horiBearingX >> 6,
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:146:19
[INFO] [stdout]     |
[INFO] [stdout] 146 |         offset_y: g_metrics.horiBearingY >> 6,
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:146:19
[INFO] [stdout]     |
[INFO] [stdout] 146 |         offset_y: g_metrics.horiBearingY >> 6,
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:248:43
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent)) as  u32;
[INFO] [stdout]     |                                  -------- ^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  arguments to this function are incorrect
[INFO] [stdout]     |
[INFO] [stdout] note: method defined here
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/num/int_macros.rs:3624:21
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/num/mod.rs:426:4
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/num/mod.rs:445:5
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]     = note: this error originates in the macro `int_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: you can convert an `i64` to an `i32` and panic if the converted value doesn't fit
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent.try_into().unwrap())) as  u32;
[INFO] [stdout]     |                                                      ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:248:43
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent)) as  u32;
[INFO] [stdout]     |                                  -------- ^^^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  arguments to this function are incorrect
[INFO] [stdout]     |
[INFO] [stdout] note: method defined here
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/num/int_macros.rs:3624:21
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/num/mod.rs:426:4
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/num/mod.rs:445:5
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]     = note: this error originates in the macro `int_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: you can convert an `i64` to an `i32` and panic if the converted value doesn't fit
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent.try_into().unwrap())) as  u32;
[INFO] [stdout]     |                                                      ++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:248:34
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent)) as  u32;
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^^^^^ expected `i64`, found `i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:248:34
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent)) as  u32;
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^^^^^ expected `i64`, found `i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot add `i32` to `i64`
[INFO] [stdout]    --> src/main.rs:248:32
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent)) as  u32;
[INFO] [stdout]     |                                ^ no implementation for `i64 + i32`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `Add<i32>` is not implemented for `i64`
[INFO] [stdout] help: the following other types implement trait `Add<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:98:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i64` implements `Add`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:113:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i64` implements `Add<i64>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i64` implements `Add<&i64>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i64` implements `Add`
[INFO] [stdout]     = note: this error originates in the macro `add_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot add `i32` to `i64`
[INFO] [stdout]    --> src/main.rs:248:32
[INFO] [stdout]     |
[INFO] [stdout] 248 |     let pixel_h = ( max_ascent + i32::abs(max_descent)) as  u32;
[INFO] [stdout]     |                                ^ no implementation for `i64 + i32`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `Add<i32>` is not implemented for `i64`
[INFO] [stdout] help: the following other types implement trait `Add<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:98:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i64` implements `Add`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:113:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i64` implements `Add<i64>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i64` implements `Add<&i64>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i64` implements `Add`
[INFO] [stdout]     = note: this error originates in the macro `add_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:278:38
[INFO] [stdout]     |
[INFO] [stdout] 278 |     let x_offset = (pixel_w as i32 - advance_x) / 2;
[INFO] [stdout]     |                                      ^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:278:38
[INFO] [stdout]     |
[INFO] [stdout] 278 |     let x_offset = (pixel_w as i32 - advance_x) / 2;
[INFO] [stdout]     |                                      ^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot subtract `i64` from `i32`
[INFO] [stdout]    --> src/main.rs:278:36
[INFO] [stdout]     |
[INFO] [stdout] 278 |     let x_offset = (pixel_w as i32 - advance_x) / 2;
[INFO] [stdout]     |                                    ^ no implementation for `i32 - i64`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `std::ops::Sub<i64>` is not implemented for `i32`
[INFO] [stdout] help: the following other types implement trait `std::ops::Sub<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:210:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:225:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub<i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub<&i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub`
[INFO] [stdout]     = note: this error originates in the macro `sub_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot subtract `i64` from `i32`
[INFO] [stdout]    --> src/main.rs:278:36
[INFO] [stdout]     |
[INFO] [stdout] 278 |     let x_offset = (pixel_w as i32 - advance_x) / 2;
[INFO] [stdout]     |                                    ^ no implementation for `i32 - i64`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `std::ops::Sub<i64>` is not implemented for `i32`
[INFO] [stdout] help: the following other types implement trait `std::ops::Sub<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:210:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:225:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub<i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub<&i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub`
[INFO] [stdout]     = note: this error originates in the macro `sub_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:282:39
[INFO] [stdout]     |
[INFO] [stdout] 282 |     let y_offset =  (pixel_h as i32 - bearing_y) /2;
[INFO] [stdout]     |                                       ^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:282:39
[INFO] [stdout]     |
[INFO] [stdout] 282 |     let y_offset =  (pixel_h as i32 - bearing_y) /2;
[INFO] [stdout]     |                                       ^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot subtract `i64` from `i32`
[INFO] [stdout]    --> src/main.rs:282:37
[INFO] [stdout]     |
[INFO] [stdout] 282 |     let y_offset =  (pixel_h as i32 - bearing_y) /2;
[INFO] [stdout]     |                                     ^ no implementation for `i32 - i64`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `std::ops::Sub<i64>` is not implemented for `i32`
[INFO] [stdout] help: the following other types implement trait `std::ops::Sub<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:210:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:225:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub<i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub<&i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub`
[INFO] [stdout]     = note: this error originates in the macro `sub_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot subtract `i64` from `i32`
[INFO] [stdout]    --> src/main.rs:282:37
[INFO] [stdout]     |
[INFO] [stdout] 282 |     let y_offset =  (pixel_h as i32 - bearing_y) /2;
[INFO] [stdout]     |                                     ^ no implementation for `i32 - i64`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `std::ops::Sub<i64>` is not implemented for `i32`
[INFO] [stdout] help: the following other types implement trait `std::ops::Sub<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:210:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:225:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub<i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `std::ops::Sub<&i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `std::ops::Sub`
[INFO] [stdout]     = note: this error originates in the macro `sub_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:287:34
[INFO] [stdout]     |
[INFO] [stdout] 287 |     let baseline_h = (y_offset + bearing_y) as u32;
[INFO] [stdout]     |                                  ^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> src/main.rs:287:34
[INFO] [stdout]     |
[INFO] [stdout] 287 |     let baseline_h = (y_offset + bearing_y) as u32;
[INFO] [stdout]     |                                  ^^^^^^^^^ expected `i32`, found `i64`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot add `i64` to `i32`
[INFO] [stdout]    --> src/main.rs:287:32
[INFO] [stdout]     |
[INFO] [stdout] 287 |     let baseline_h = (y_offset + bearing_y) as u32;
[INFO] [stdout]     |                                ^ no implementation for `i32 + i64`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `Add<i64>` is not implemented for `i32`
[INFO] [stdout] help: the following other types implement trait `Add<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:98:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `Add`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:113:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `Add<i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `Add<&i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `Add`
[INFO] [stdout]     = note: this error originates in the macro `add_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: cannot add `i64` to `i32`
[INFO] [stdout]    --> src/main.rs:287:32
[INFO] [stdout]     |
[INFO] [stdout] 287 |     let baseline_h = (y_offset + bearing_y) as u32;
[INFO] [stdout]     |                                ^ no implementation for `i32 + i64`
[INFO] [stdout]     |
[INFO] [stdout]     = help: the trait `Add<i64>` is not implemented for `i32`
[INFO] [stdout] help: the following other types implement trait `Add<Rhs>`
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:98:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `Add`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/ops/arith.rs:113:0
[INFO] [stdout]     |
[INFO] [stdout]     = note: in this macro invocation
[INFO] [stdout]    --> /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:22:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `Add<i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:33:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `i32` implements `Add<&i32>`
[INFO] [stdout]    ::: /rustc/b152f5575a2ac7126ae0019e4e679abe9399213e/library/core/src/internal_macros.rs:44:8
[INFO] [stdout]     |
[INFO] [stdout]     = note: `&i32` implements `Add`
[INFO] [stdout]     = note: this error originates in the macro `add_impl` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/fntfont.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut out_img = p.image.clone();
[INFO] [stdout]    |             ----^^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/fntfont.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut page_id = 0;
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `h`
[INFO] [stdout]   --> src/fntfont.rs:52:13
[INFO] [stdout]    |
[INFO] [stdout] 52 |         let h = img.height();
[INFO] [stdout]    |             ^ help: if this is intentional, prefix it with an underscore: `_h`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/fntfont.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut out_img = p.image.clone();
[INFO] [stdout]    |             ----^^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/fntfont.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut page_id = 0;
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `h`
[INFO] [stdout]   --> src/fntfont.rs:52:13
[INFO] [stdout]    |
[INFO] [stdout] 52 |         let h = img.height();
[INFO] [stdout]    |             ^ help: if this is intentional, prefix it with an underscore: `_h`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/fntfont.rs:172:9
[INFO] [stdout]     |
[INFO] [stdout] 172 |     let mut res = format!("kernings count={}\n", kernings.len());
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `k`
[INFO] [stdout]    --> src/fntfont.rs:174:9
[INFO] [stdout]     |
[INFO] [stdout] 174 |     for k in kernings  {
[INFO] [stdout]     |         ^ help: if this is intentional, prefix it with an underscore: `_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]   --> src/main.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let args = std::env::args();
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `lineheight`
[INFO] [stdout]   --> src/main.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |     let lineheight = face.height() >> 6;
[INFO] [stdout]    |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_lineheight`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:226:9
[INFO] [stdout]     |
[INFO] [stdout] 226 |     let mut res = scaled / 2.0 + 0.5;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/fntfont.rs:172:9
[INFO] [stdout]     |
[INFO] [stdout] 172 |     let mut res = format!("kernings count={}\n", kernings.len());
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `k`
[INFO] [stdout]    --> src/fntfont.rs:174:9
[INFO] [stdout]     |
[INFO] [stdout] 174 |     for k in kernings  {
[INFO] [stdout]     |         ^ help: if this is intentional, prefix it with an underscore: `_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]   --> src/main.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let args = std::env::args();
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `lineheight`
[INFO] [stdout]   --> src/main.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |     let lineheight = face.height() >> 6;
[INFO] [stdout]    |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_lineheight`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:226:9
[INFO] [stdout]     |
[INFO] [stdout] 226 |     let mut res = scaled / 2.0 + 0.5;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0277, E0308.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0277, E0308.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0277`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `rust-sdf-tool` (bin "rust-sdf-tool") due to 12 previous errors; 12 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: could not compile `rust-sdf-tool` (bin "rust-sdf-tool" test) due to 12 previous errors; 12 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6", kill_on_drop: false }`
[INFO] [stdout] 45fea12fe33d5b7e05580ac1fed83d9bd6a07c4e4175c241188e8a7bb01f84d6
